草庐IT

MySQL group-by 非常慢

全部标签

ruby - 在 Passenger 中禁用 X-powered-by header 的标准方法?

我找不到任何方法来禁用Passenger的X-Powered-Byheader:X-Powered-By:PhusionPassenger(mod_rails/mod_rack)3.0.11是否可以在不修改其源和在HTTP服务器级别删除header的情况下做到这一点? 最佳答案 在Apache上,您可以取消设置header:#Hide/RemovethePassengerHeadersHeaderalwaysunset"X-Powered-By"Headeralwaysunset"X-Runtime"它不会删除所有名称(因为Ples

RubyGems + Cygwin : POSIX path not found by ruby. exe

我是Windows上的Ruby程序员,试图从Wincmd切换到Cygwin,但无法执行Rubygems的批处理文件。我已经将任何bin目录填充到WindowsPATH环境中。变量,包括存储可执行文件的Rubybin。然而,gems是由ruby​​.exe本身调用的,这会导致以下POSIX路径问题:duddle@duddledan/cygdrive/c/Ruby/ruby-186-398/bin$gem-vC:\Ruby\ruby-186-398\bin\ruby.exe:Nosuchfileordirectory--/cygdrive/c/Ruby/ruby-186-398/bin/g

ruby-on-rails - 使用 Rails 中的命名空间类防止 "warning: toplevel constant B referenced by A::B"

在自定义目录(例如:app/presenters/)中存储文件时,如何确保加载命名空间类?例如,如果您有:app/models/mega_menu.rbapp/presenters/catalog_presenter.rbapp/presenters/mega_menu/catalog_presenter.rbRails无法加载MegaMenu::CatalogPresenter:CatalogPresenter.new=>#MegaMenu::CatalogPresenter.new(irb):3:warning:toplevelconstantCatalogPresenterref

ruby-on-rails - Ruby 哈希数组。 group_by 一行修改

我有一个散列数组,类似于[{:type=>"Meat",:name=>"one"},{:type=>"Meat",:name=>"two"},{:type=>"Fruit",:name=>"four"}]我想把它转换成这个{"Meat"=>["one","two"],"Fruit"=>["Four"]}我尝试了group_by但后来我得到了这个{"Meat"=>[{:type=>"Meat",:name=>"one"},{:type=>"Meat",:name=>"two"}],"Fruit"=>[{:type=>"Fruit",:name=>"four"}]}然后我不能修改它只留下名

ruby-on-rails - Ruby 有 natural_sort_by 方法吗?

我有一个包含一堆属性的文件列表。其中一个属性是文件名,这是我想要对列表进行排序的方式。然而,列表是这样的:文件名1、文件名2、文件名10、文件名20。rubysort_by方法产生这个:files=files.sort_by{|file|file.name}=>[filename1,filename10,filename2,filename20]我想要一个更易于阅读的列表,例如文件名1、文件名2、文件名10、文件名20我找到了natural_sortgem但它似乎只能像排序方法一样工作。我需要一些可以指定数组排序依据的东西。有什么帮助吗? 最佳答案

ruby - 一个在 Ruby 上表现非常糟糕的简单正则表达式

我有一个简单的Ruby正则表达式,需要很长时间才能计算:"fußball"*20=~/^([\S\s]{1000})/i如果我删除/i标志,它会工作得非常快。为什么运行这么慢?(我没有等到执行完毕)我知道这个正则表达式可能没有意义,但我想知道幕后是什么。错误报告:https://bugs.ruby-lang.org/issues/14418 最佳答案 默认.不匹配换行符。[\s\S]是解决该问题的方法。在Ruby中,您可以使用/m标志使点匹配所有字符。它在文档中RubyMetacharactersandEscapes[\S\s]由于

ruby-on-rails - rails : Plus sign in GET-Request replaced by space

在Rails3(Ruby1.9.2)中我发送一个请求StartedGET"/controller/action?path=/41_+"但是参数列表是这样的:{"path"=>"/41_","controller"=>"controller","action"=>"action"}这里出了什么问题?-、*或.符号工作正常,只是+将被空格替换。 最佳答案 这是正常的URL编码,theplussignisashorthandforaspace:Withinthequerystring,theplussignisreservedasshor

ruby-on-rails - 在 ruby​​ 中使用 sort_by(对于 rails)?

所以我构建了一个自定义用户数组,如下所示:[["user1",432],["user1",53],["user9",58],["user5",75],["user3",62]]我想按每个数组中的第2个值从大到小对它们进行排序。我觉得对数组使用sort或sort_by是做到这一点的方法,但我不太确定如何完成它 最佳答案 排序方式如果您对sort_by感兴趣,您可以解构您的内部数组array.sort_by{|_,x|x}.reverse或者调用索引运算符array.sort_by{|x|x[1]}.reverse您可以取反从block

ruby 方式 : catch division by zero

我有以下方法来计算平均值:defcompute_average(a,b,c,d,e)total=[a,b,c,d,e].sum.to_faverage=[a,2*b,3*c,4*d,5*e].sum/totalaverage.round(2)end这没什么特别的,但它有一个问题,我认为所有平均方程都有:如果输入全为零,它可能被零除。所以,我想到了这样做:defcompute_average(a,b,c,d,e)total=[a,b,c,d,e].sum.to_fiftotal==0average=0.00elseaverage=[a,2*b,3*c,4*d,5*e].sum/total

ruby-on-rails - Rails 在 ruby​​ 1.9.1 上初始化非常慢

我刚刚让我的Rails2.3.8应用程序在ruby​​1.9.1上运行。要进入控制台,启动网络服务器,任何初始化rails的东西,在ruby​​1.9中比在ruby​​1.8.7中花费3-4倍的时间。我正在使用ruby​​版本管理器,因此我可以轻松地在ruby​​1.9和ruby​​1.8.7之间切换。速度差异发生在生产和开发中。我想使用1.9,因为一旦一切都在运行,它必须更快,但启动时间太糟糕了,应用程序在第一次请求时在Heroku上超时。知道为什么ruby​​1.9会慢3-4倍吗?我这辈子都想不通。 最佳答案 尝试使用1.9.2